# LLVM中RISC-V 子扩展的支持现状

廖春玉 chunyu@iscas.ac.cn

## 简介 - 来自上次4月22号的报告

针对RISCV的代码实现:

https://github.com/llvm/llvm-project/tree/main/llvm/lib/Target/RISCV

AsmParser CMakeLists.txt Disassembler GISe1 MCA **MCTargetDesc** RISCVAsmPrinter.cpp RISCVCallingConv.td RISCVCodeGenPrepare.cpp RISCVExpandAtomicPseudoInsts.cpp RISCVExpandPseudoInsts.cpp RISCVFeatures.td RISCVFrameLowering.cpp RISCVFrameLowering.h RISCVGatherScatterLowering.cpp RISCV.h RISCVInsertNTLHInsts.cpp RISCVInsertVSETVLI.cpp RISCVInstrFormatsC.td

RISCVInstrFormats.td

RISCVInstrFormatsV.td RISCVInstrInfoA.td RISCVInstrInfo.cpp RISCVInstrInfoC.td RISCVInstrInfoD.td RISCVInstrInfoF.td RISCVInstrInfo.h RISCVInstrInfoM.td RISCVInstrInfo.td RISCVInstrInfoVPseudos.td RISCVInstrInfoVSDPatterns.td RISCVInstrInfoV.td RISCVInstrInfoVVLPatterns.td RISCVInstrInfoXSf.td RISCVInstrInfoXTHead.td RISCVInstrInfoXVentana.td RISCVInstrInfoZb.td RISCVInstrInfoZc.td RISCVInstrInfoZfa.td RISCVInstrInfoZfh.td

RISCVInstrInfoZicbo.td RISCVInstrInfoZicond.td RISCVInstrInfoZihintntl.td RISCVInstrInfoZk.td RISCVInstrInfoZvk.td RISCVISelDAGToDAG.cpp RISCVISelDAGToDAG.h RISCVISelLowering.cpp RISCVISelLowering.h RISCVMachineFunctionInfo.cpp RISCVMachineFunctionInfo.h RISCVMacroFusion.cpp RISCVMacroFusion.h RISCVMakeCompressible.cpp RISCVMCInstLower.cpp RISCVMergeBaseOffset.cpp RISCVOptWInstrs.cpp RISCVProcessors.td RISCVRedundantCopvElimination.cpp RISCVRegisterInfo.cpp

RISCVRegisterInfo.h RISCVRegisterInfo.td RISCVRVVInitUndef.cpp RISCVSchedRocket.td RISCVSchedSiFive7.td RISCVSchedSvntacoreSCR1.td RISCVSchedule.td RISCVScheduleV.td RISCVScheduleZb.td RISCVSubtarget.cpp RISCVSubtarget.h RISCVSystemOperands.td RISCVTargetMachine.cpp RISCVTargetMachine.h RISCVTargetObjectFile.cpp RISCVTargetObjectFile.h RISCVTargetTransformInfo.cpp RISCVTargetTransformInfo.h RISCV.td

TargetInfo

## RISC-V使用

● 尝试使用: https://godbolt.org/

- 本地编译Clang/LLVM
- git clone git@github.com:llvm/llvm-project.git
- cd Ilvm-project
- mkdir build
- cd build
- cmake -DLLVM\_TARGETS\_TO\_BUILD="X86;RISCV" -DLLVM\_ENABLE\_PROJECTS="clang"
  -DCMAKE\_BUILD\_TYPE="Release" -G Ninja ../Ilvm
- ninja
- ninja check

#### What's new for RISC-V in LLVM 16

- https://muxup.com/2023q1/whats-new-for-risc-v-in-llvm-16
  - 优化
  - 子扩展
  - Ild/Ildb等

● User Guide for RISC-V Target <a href="https://llvm.org/docs/RISCVUsage.html">https://llvm.org/docs/RISCVUsage.html</a> --后面看

## RISC-V扩展

- RISC-V is augmented via the concept of extensions
  - Extensions can add new instructions and CPU state
- Base ISA is called I (for Integer)
  - RV32I
  - RV64I (XLEN=64, adds a few arithmetic instructions to improve 32-bit integer arithmetic)
- Common Standard Extensions in a RISC-V 64-bit Linux capable core
  - M. Integer multiplication and division (mul, div, rem, ...)
  - A. Atomic instructions (load reserve + store conditional, atomic read-modify-write)
  - F. Single-Precision Floating-Point (IEEE 754 Binary32)
  - D. Double-Precision Floating-Point (IEEE 754 Binary64)
  - C. Compressed Instructions (16-bit encodings for common I/F/D instructions)

IMAFD = G

## RISC-V扩展

- RISC-V有多少个扩展呢????
- 几个由我们小队实现的扩展,每个扩展都有独特的的意义
  - o z\*inx
  - **ZC**\*
  - k扩展

### z\*inx

- SPEC
  - 很早之前: <u>https://github.com/riscv/riscv-zfinx</u>
  - 现在也可以: <u>https://github.com/riscv/riscv-isa-manual/releases</u>
- LLVM
  - 大部分都可以从upstream中直接获取
  - 最难的部分rv32 zdinx : https://reviews.llvm.org/D149743

#### ZC\*

- SPEC
  - https://github.com/riscv/riscv-code-size-reduction
- psABI
  - Zcmt, <a href="https://github.com/riscv-non-isa/riscv-elf-psabi-doc/pull/349">https://github.com/riscv-non-isa/riscv-elf-psabi-doc/pull/349</a>
- LLVM
  - 汇编器全部支持
  - zcmp codegen 还在进行中https://reviews.llvm.org/search/query/wO31sK76dGV\_/#R
  - zcmt lld 还在进行中 <a href="https://reviews.llvm.org/D134600">https://reviews.llvm.org/D134600</a>

## RISC-V扩展

- Spec
  - 用途,编码,别名,pseudo。。。。
  - https://github.com/riscv/riscv-isa-manual
- intrinsic标准
  - rvv intrinsic见证发展的艰辛
    https://github.com/riscv-non-isa/rvv-intrinsic-doc
- 厂商指令

## LLVM中已经支持的扩展

User Guide for RISC-V Target <a href="https://llvm.org/docs/RISCVUsage.html">https://llvm.org/docs/RISCVUsage.html</a>

## 如何在LLVM中贡献RISC-V扩展

- 大方向没有争议的扩展downstream
- upstream
  - o mc
  - codegen
  - o clang
  - 0 .....

## 如何在LLVM中贡献RISC-V扩展

- 大方向有争议的扩展
- 积极参与各种实现方式都尝试
  - o zmmul <a href="https://reviews.llvm.org/D103313">https://reviews.llvm.org/D103313</a>
  - o no-div

## 现在还有机会吗?

- 公共子扩展
  - 关注RISC-V
  - 关注其他编译器/软件
- 厂商扩展- CORE-V
  - https://github.com/openhwgroup/cv32e40p/blob/master/docs/source/instruction\_set\_extension\_s.rst
  - https://github.com/riscv-non-isa/riscv-toolchain-conventions/pull/29

## 各个扩展的具体实现

- vscode k-ext
- fclass.d
- 还有什么想看的扩展吗?现场一起学习